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MULTIPLE TRAP AVOIDANCE MECHANISM 

BACKGROUND OF THE INVENTION 

5 The invention relates to the control of access to system resources in a computer 
system. 

A problem that the present invention addresses is the control of access to resources in 
a computer system in the event of an error related to the resource to be accessed. The 

10 resource can be, for example, a memory location or a block of memory, a memory 
device, a peripheral device, etc. The error can be as a result of a failure of the 
resource itself, or a failure along the communication path from the processor to the 
resource or faulty programming of an application program or of an operating system. 
In the event of an error, a trap can be taken by the processor to process the fault. 

15 Where multiple accesses are attempted to the same resource, multiple traps will be 
taken. The result of this is that an increasing amount of processor time can be 
absorbed in processing the fault. 

US patent 5,627,965 describes a fault tolerant computer system including a central 
20 processor sub-system and a plurality of other subsystems, the subsystems being 

connected via a main data transfer bus. The central processor subsystem comprises 
three central processor modules. Each central processor module (or CPUset) includes 
a central processing unit (CPU) connected to a private bus, a first bus interface 
connecting the private bus to a shared bus, and a second bus interface connecting the 
25 shared bus to the main bus. The CPUsets are connected over respective^private buses 
to a shared bus. Connected to the shared bus is a slot response memory. The slot 
response memory includes locations corresponding to respective slots for subsystems 
on the main bus. According to column 15 of US patent 5,627,965, where a subsystem 
in a slot is functioning correctly, a location in the slot response memory corresponding 
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to that slot will contain '0' data and the slot response register will not interfere with 
data transfers on the main bus. Where the subsystem in a slot becomes defective or 
absent from the system, then the location in the slot response memory corresponding 
to that slot is set to 4 V and all subsequent attempts to access the defective or absent 
5 subsystem will result in artificial termination of the data transfer attempt. 

PCT application PCT/US99/12605 is directed to a bridge for a fault tolerant computer 
system, which bridge connects I/O buses of first and second processing sets to a 
common I/O device bus. A resource control mechanism in the bridge provides an 

10 interface for exchanging signals with one or more resource slots of the device bus, 
each of the resource slots being capable of communicating with a system resource. 
The resource control mechanism in the bridge also includes a register associated with 
each system resource, the register having switchable indicia that indicate an operating 
state of the associated system resource. The control mechanism is operable in use to 

15 direct signals to and/or from respective system resources of the computer system. 

The prior arrangements for resource access control as described above have required 
the provision of a specific system configuration to achieve this, and particularly in the 
context of a fault tolerant computing system. As a result, such resource access control 
20 arrangements are not generally applicable to more conventional computer systems. 

An aim of the present invention is to provide an improved approach to resource access 
control that is applicable to many types of computer systems. 
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SUMMARY OF THE INVENTION 

Particular and preferred aspects of the invention are set out in the accompanying 
independent and dependent claims. Combinations of features from the dependent 
5 claims may be combined with features of the independent claims as appropriate and 
not merely as explicitly set out in the claims. 

In one aspect, the invention provides a resource access control mechanism for a 
computer system including at least one central processing unit. The resource access 

10 control mechanism includes an address translation mechanism for mapping a received 
address to a resource. A trap handler handles a trap in the event of a faulty resource 
access being detected. The trap handler is operable to instigate a diversion for 
subsequent access attempts to the resource. The address translation mechanism is 
responsive to instigation of a diversion by the trap handler to effect the diversion for 

15 subsequent attempts to access the resource. 

In an embodiment of the invention, therefore, a trap handler, which can be arranged in 
a conventional manner to process an exception in the event of a first faulty access to a 
resource, can instigate a diversion in an address translation mechanism. In this 
20 manner, subsequent access attempts to the same resource will result in the access 
attempt being diverted to a valid (but different) resource. As the system will already 
be treating the resource as faulty, the fact that the access attempt goes to a resource 
other than that intended will not cause any further problems, but it will mean that the 
processor does not have to process another exception for a faulty resource access. 



The diversion can be instigated by the trap handler identifying an alternative resource 
address to the address translation mechanism. The diversion can then be effected by 
the address translation mechanism replacing a resource address held in an address 
translation entry for the resource with the alternative resource address. 
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Alternatively, the trap handler can instigate the diversion by simply signaling the 
address translation mechanism to effect the diversion. 

5 The address translation mechanism can then react in various ways. 

For example, the address translation mechanism can be arranged to replace the usual 
address translation with an alternative one from some predefined register or memory 
address. 



Alternatively, the address translation mechanism can be arranged to set a divert flag in 
a translation entry of the address translation. The address translation mechanism can 
then be arranged to respond to a received address relating to an address translation 
entry having a divert flag that is set to use an alternative address to that held in the 
15 address translation entry (e.g., in some register or memory address). As a further 
alternative, the address translation mechanism can be arranged to respond to a 
received address relating to an address translation entry having a divert flag that is set 
to modify an address held in the address translation entry. 

20 If desired, the diversion can be arranged to direct subsequent accesses to a fake 
response generator operable to generate a faked response to the resource access. 

Alternatively, the diversion could point to a predefined memory portion (either 
directly or indirectly) whereby a response can be provided from a conventional 
25 memory controller. 



10 



The address translation mechanism can include a translation look-aside buffer, and 
can form part of a memory management unit. The resource concerned could be one or 
more of at least one memory location, a peripheral device, or a subsystem. 
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Another aspect of the invention provides a computer system comprising at least one 
processor that includes at least one central processing unit, memory, at least one 
peripheral device and a resource access control mechanism as set out above. 

5 

The computer system can be operable to identify an initial faulty access to a resource. 
It can be further operable in response to the initial indication of a faulty resource 
access to cause the resource access controller to set a fake response indication for a 
corresponding translation entry for said faulty resource access. 

10 

A further aspect of the invention provides a method of managing processor access to 
resources in a computer system. The method includes: 

handling a trap in the event of an initial faulty access attempt to a resource being 
detected; 

15 defining a diversion for subsequent access attempts to the same resource; and 
diverting subsequent access attempts to the resource diversion. 

The invention also provides a computer program forming a trap handler for a 
computer system as set out above. The computer program comprises computer code 
20 operable to respond to faulty resource access by processing an exception and 

instigating a diversion in an address translation mechanism for subsequent access 
attempts to the resource. 

The computer program can be in the form of program code carried by a carrier 
25 medium. The carrier medium could be a storage medium or a transmission medium, 
for example. 



An embodiment of the invention can find applicability to computing systems 
including one or more processors, whether the computing systems are designed 
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specifically to be fault tolerant or whether the computing systems are designed for 
more general use. 
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DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Exemplary embodiments of the present invention will be described hereinafter, by 
way of example only, with reference to the accompanying drawings in which like 
5 reference signs relate to like elements and in which: 

Figure 1 is a schematic overview of a computer system; 

Figure 2 is a schematic overview of a processor of the computer system of Figure 1 ; 
Figure 3 is a schematic block diagram of a known type of processor; 
10 Figure 4 is a schematic overview of a subsystem including the processor of Figure 3; 
Figure 5 illustrates virtual to physical address translation for the processor of Figure 3; 
Figure 6 illustrates an example of the relationship between virtual and physical 
address space for the processor of Figure 3; 

Figure 7 is a schematic block diagram illustrating a software view of an example of 
15 the memory management unit of the processor of Figure 3; 

Figure 8 illustrates a translation table entry for the memory management unit referred 
to with reference to Figure 7; 

Figure 9 is a schematic block diagram of software components of a first exemplary 
implementation of the invention; 
20 Figure 10 is a flow diagram illustrating the operation of a schematic block diagram of 
an exemplary embodiment of the invention. 




• 
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DESCRIPTION OF PARTICULAR EMBODIMENTS 

Exemplary embodiments of the present invention are described in the following with 
reference to the accompanying drawings. 

5 

Figure 1 is an overview of a computer system 10 that includes a processor 12, a 
processor bus 14 to which are attached a plurality of subsystems including memory 16 
and an I/O bridge 18. The processor 12 can typically be integrated in a single 
integrated circuit. The I/O bridge 1 8 provides an interface between the processor bus 
10 14 and an I/O bus 20 to which a plurality of I/O devices 22 can be connected. 

Figure 2 is a schematic overview of a processor such as the processor 12 of Figure 1. 
This includes a central processing unit (CPU) 24 connected via an internal bus 26 to a 
memory management unit (MMU) 28. The CPU 24 is operable to output virtual 
15 addresses on the internal bus 26 that are then converted by the MMU 28 into physical 
addresses for accessing system resources including the memory 16 and the I/O devices 



Figure 3 is a schematic block diagram of one type of processor 12, namely an 
20 UltraSPARC™ processor marketed by Sun Microsystems, Inc. Further details of the 
UltraSPARC™ processor can be found, for example, in the UltraSPARC™ I&II 
User's Manual, January 1997, available from Sun Microsystems, Inc, the content of 
which is incorporated herein by reference. The present invention can be implemented 
in a processor having the general overall structure of Figure 3, although it should be 
25 appreciated that the invention could equally be implemented in processors having 
other structures. 



22. 



In order to explain the present invention, there follows a description of the processor 
shown in Figure 3. 
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The UltraSPARC processor is a high-performance, highly integrated superscalar 
processor implementing a 64-bit architecture. The processor pipeline is able to 
execute up to four instructions in parallel. 

5 

A Prefetch and Dispatch Unit (PDU) 30 fetches instructions before they are actually 
needed in the pipeline, so the execution units do not starve for instructions. Prefetched 
instructions are stored in the Instruction Buffer 32 until they are sent to the rest of the 
pipeline. An instruction cache (I-cache) 33 is a 16 Kbyte two-way set associative 
10 cache with 32 byte blocks. 

An Integer Execution Unit (IEU) 34 includes two arithmetic logic units (ALUs), a 
multi-cycle integer multiplier, a multi-cycle integer divider, eight register windows, 
four sets of global registers (normal, alternate, MMU, and interrupt globals) and trap 
15 registers. 

A Floating- Point Unit (FPU) 36 is partitioned into separate execution units, which 
allow two floating-point instructions to be issued and executed per cycle. Source and 
result data are stored in a 32-entry Floating Point (FP) register file (FP Reg) 38. FP 
20 multiply 40, FP Add 42 and FP Divide 44, are all catered for. A Graphics Unit (GRU) 
45 provides a comprehensive set of graphics instructions. 

The Memory Management Unit (MMU) 28 provides mapping between a 44-bit virtual 
address and a 41 -bit physical address. This is accomplished through a 64-entry 
25 instructions translation look-aside buffer (iTLB) 46 for instructions and a 64-entry 
data translation look-aside buffer (dTLB) 48 for data under the control of MMU 
control logic 50. Both TLBs are fully associative. The control logic 50 also provides 
hardware support for a software-based TLB miss strategy. A separate set of global 
registers 52 is available to process MMU traps. 
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A Load/Store Unit (LSU) 54 is responsible for generating the virtual address of all 
loads and stores for accessing a data cache (D-Cache) 56, for decoupling load misses 
from the pipeline through a load buffer 58, and for decoupling stores through a store 
5 buffer 59. 

An External Cache Unit (ECU) 60 handles I-Cache 33 and D-Cache 56 misses 
efficiently. The ECU 60 can handle one access per cycle to an External Cache (E- 
Cache) 62. The ECU 60 provides overlap processing during load and store misses. 
10 For instance, stores that hit the E-Cache 62 can proceed while a load miss is being 
processed. The ECU 60 can process reads and writes and also handle snoops. Block 
loads and block stores, which load/store a 64-byte line of data from memory to the 
floating-point register file, are also processed by the ECU 60 to provide high transfer 
bandwidth without polluting the E-Cache 62. 



A Memory Interface Unit (MIU) 64 handles all transactions to the system controller, 
for example, external cache misses, interrupts, snoops, writebacks, and so on. 

Figure 4 is a schematic overview of the UltraSPARC™ processor subsystem 66, 
20 which comprises the UltraSPARC™ processor 12, synchronous SRAM components 
for E-Cache tags and data 621 and 622, and two UltraSPARC™ data buffer (UDB) 68 
chips. Typically, the processor 12 will be integrated in a single integrated circuit. The 
UDBs 68 isolate, the E-Cache 62 from the system, provide data buffers for incoming 
and outgoing system transactions, and provide error correction code (ECC) generation 
25 and checking. 



15 



There now follows a description of the Memory Management Unit (MMU) 28 as it is 
seen by operating system software. In this example, a 44-bit virtual address space is 
supported with 41 bits of physical address. During each processor cycle the MMU 28 
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provides one instruction and one data virtual-to-physical address translation. In each 
translation, the virtual page number is replaced by a physical page number, which is 
concatenated with the page offset to form the full physical address, as illustrated in 
Figure 5 for each of four page sizes, namely 8 Kb, 64 Kb, 512 Kb, and 4 Mb. It 
5 should be noted that this Figure shows a full 64-bit virtual address, even though only 
44 bits of Virtual Address (VA) are supported, as mentioned above. 

44-bit virtual address space is implemented in two equal halves at the extreme lower 
and upper portions of the full 64-bit virtual address space. Virtual addresses between 
10 0000 0800 0000 0000 16 and FFFF F7FF FFFF FFFFi 6 , inclusive, are termed "out of 
range" and are illegal for the UltraSPARC™ virtual address space. In other words, 
virtual address bits VA<63:44> must be either all zeros or all ones. Figure 6 
illustrates the UltraSPARC™ virtual address space. 

15 Figure 7 is a block diagram illustrating the software view of the MMU 28. The 
operating system maintains translation information in a data structure called the 
Software Translation Table (STT) 70. The MMU 28 is effectively divided into an 
instruction MMU (I-MMU) 281 and a data MMU (D-MMU) 282. The I-MMU 281 
includes the hardware instructions Translation Lookaside Buffer (iTLB) 46 and the D- 

20 MMU 282 includes the hardware instructions Translation Lookaside Buffer (dTLB) 
48. These TLBs 46 and 48 act as independent caches of the Software Translation 
Table 70, providing one-cycle translation for the more frequently accessed virtual 
pages. 

25 The STT 70, which is kept in memory, is typically large and complex compared to the 
relatively small hardware TLBs 46 and 48. A Translation Storage Buffer (TSB) 72, 
which acts like a direct-mapped cache, provides an interface between the STT 70 and 
the TLBs 46 and 48. The TSB 72 can be shared by all processes running on a 
processor, or it can be process specific. 
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When performing an address translation, a "TLB hit" occurs when a desired 
translation is present in the MMU's on-chip TLBs 46/48. A "TLB miss" occurs when 
a desired translation is not present in the MMU's on-chip TLBs 46/48. On a TLB 
5 miss the MMU 28 immediately traps to software for TLB miss processing. A 

software TLB miss handler has the option of filling the TLB by any means available, 
but it is likely to take advantage of TLB miss hardware support features provided by 
the MMU control logic 50, since the TLB miss handler is time critical code. 

10 There now follows more information on the UltraSPARC™ Memory Management 
Unit (MMU) 28. 

An example of an UltraSPARC™ Translation Table Entry (TTE) of the TSB 72 is 
shown in Figure 8. This provides a translation entry that holds information for a 
15 single page mapping. The TTE is broken into two 64-bit words, representing the tag 
and data of the translation. Just as in a hardware cache, the tag is used to determine 
whether there is a hit in the TSB 72. If there is a hit, the data is fetched by software. 
The functions of fields of the tag and data words are described below. 

20 Tag Word 

G - This is a Global bit. If the Global bit is set, the Context field of the TTE is 
ignored during hit detection. This allows any page to be shared among all (user or 
supervisor) contexts running in the same processor. The Global bit is duplicated in the 
25 TTE tag and data to optimize the software miss handler. 

Context - This is a 13-bit context identifier associated with the TTE. 



VA-tag<63:22> - The Virtual Address tag is the virtual page number. 
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Data Word 

V - This is a Valid bit. If the Valid bit is set, the remaining fields of the TTE are 
5 meaningful. 

Size - This is the page size for this entry. 

NFO - This is No-Fault-Only bit. If this bit is set, selected specific loads are 
10 translated, but all other accesses will trap with a data_access_exception trap. 

IE - This is an Invert Endianness bit. If this bit is set, accesses to the associated page 
are processed with inverse endianness from what is specified by the instruction (big- 
for-little and little-for-big). 

15 Soft<5:0>, Soft2<8:0> - These are software-defined fields provided for use by the 
operating system. The Soft and Soft2 fields may be written with any value. 

Diag - This is a field used by diagnostics to access the redundant information held in 
the TLB structure. Diag<0>=Used bit, Diag<3 : 1>=RAM size bits, Diag<6:4>=CAM 
20 size bits. 

PA<40: 13> - This is the physical page number. Page offset bits for larger page sizes 
in the TTE (PA<15:13>, PA<18:13>, and PA<21:13> for 64Kb, 512Kb, and 4Mb 
pages, respectively) are stored in the TLB and returned for a Data Access read, but are 
25 ignored during normal translation. 



L - This is a Lock bit. If this bit is set, the TTE entry will be "locked down" when it 
is loaded into the TLB; that is, if this entry is valid, it will not be replaced by the 
automatic replacement algorithm invoked by an ASI store to the Data-in register. 




SUN REF: P5128 15 SUN PROPRIETARY/ 

CONFIDENTIAL 



CP, CV - These form cacheable-in-physically-indexed-cache and cacheable-in- 
virtually-indexed cache bits to determine the placement of data in UltraSPARC™ 
caches. The MMU does not operate on the cacheable bits, but merely passes them 
5 through to the cache subsystem. 

E - This is a Side-effect bit. If this bit is set, speculative loads and FLUSHes will trap 
for addresses within the page, noncacheable memory accesses other than block loads 
and stores are strongly ordered against other E-bit accesses, and noncacheable stores 
10 are not merged. 

P - This is a Privileged bit. If this bit is set, only the supervisor can access the page 
mapped by the TTE. If the P bit is set and an access to the page is attempted when 
PSTATE.PRIV=0, the MMU will signal an instruction _access _exception or 
1 5 data_accessjsxception trap (FT= lie). 

W - This is a Writable bit. If the W bit is set, the page mapped by this TTE has write 
permission granted. Otherwise, write permission is not granted and the MMU will 
cause a data_access protection trap if a write is attempted. The W-bit in the I-MMU 
20 is read as zero and ignored when written. 

G - This is identical to the Global bit in the TTE tag word. The Global bit in the TTE 
tag word is used. for the TSB hit comparison, while the Global bit in the TTE data 
word facilitates the loading of a TLB entry. 

25 

The above description of the UltraSPARC™ processor represents an example of a 
prior art processor. In the following, the application of an embodiment of the 
invention in the context of such a processor is to be described, it being understood that 





SUN REF: P5128 



16 



SUN PROPRIETARY/ 
CONFIDENTIAL 



the invention can equally be applied to processors of alternative designs and 
configurations. 

The present invention relates to the control of resource access in a processor such as 
5 described above, or in such alternative designs and configurations. In particular, the 
invention relates to providing a solution to the problem found in conventional 
systems, whereby multiple traps are taken, and multiple exception processing is 
performed, each time access is effected to a faulty resource. 

10 Where a faulty resource access, as effected for example by a mis-configured or badly 
written program (or portion of an operating system), is identified by a processor, this 
is conventionally dealt with by taking a trap or an interrupt. Likewise where accesses 
are made to faulty or missing peripheral devices, it is conventional for this to be dealt 
with by a hardware trap or interrupts. These exceptions take time to handle. If 

15 exception handling is required for a single faulty access, then this can normally be 
accommodated without a significant impact on system performance. However, where 
such faulty accesses are performed repeatedly, this can lead to a significant reduction 
in performance. Accordingly, the invention seeks to provide a mechanism whereby 
accesses may be dropped where repeated access to a faulty resource is attempted, 

20 whereby the requirement for taking repeated traps and handling repeated exceptions 
with the consequential logging of exception data in response to repeated faulty 
accesses to the same resource address can be avoided. 

In the following, an embodiment of the invention will be described in which 
25 modifications are made to a conventional processor as described above. 



Figure 9 is a schematic representation of various software elements in the memory 16 
of the processor shown in Figure 1. As represented in Figure 9, an operating system 
80 is provided with one or more trap handlers 82. In an embodiment of the invention, 
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the trap handlers are modified with respect to a conventional trap handler to reference 
a divert page address 84. The divert page address 84 can be held in a register of a 
predefined storage location. The trap handler 82 supplies the divert page address to 
the address translation mechanism, in the present instance the memory management 
5 unit 28 of the processor shown in Figure 1 . 

The divert page address 84 is used to modify the address translation mapping in the 
memory management unit for the resource which was faulty and which led to the trap 
handler 82 having to process an exception. The changing of the mapping is performed 

10 by the control logic of the memory management unit 28 in response to a command 
from the trap handler, which command identifies the resource address which lead to 
the fault, and also the divert page address. Storing the divert page address in the TTE 
corresponding to the resource concerned changes the mapping in the MMU to point to 
a reliable resource, for example a page 86 of memory. The page 86 of memory can 

15 simply be used as a sink into which faulty accesses are directed. In such a case, the 
automatic acknowledgement generated by the memory subsystem will provide a 
response to the access. Alternatively, the divert page address 84 could indicate a 
hardware faked response generator 88 that responds to any address within a given 
range, for example a range of at least one page, to provide a faked response. 

20 

Figure 10 gives an overview of the operation of an embodiment of the invention. In 
step S 1 , there is shown a first attempt to access a particular resource R. In step S2 5 the 
address of that resource access is translated using the standard address translation in 
the address translation mechanism formed by the MMU 28. However, as the resource 
25 is faulty, in step S3 the resource access fails. 

This leads to a trap being taken and the trap handler being invoked in step S4. The 
trap handler is then operable in step S5 to supply or otherwise identify the divert 
address, which can be held in a register, or in a specific memory location, to the 
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address translation mechanism. The address translation mechanism is then operable 
in step S6 to modify the TTE for the resource concerned. The modification of the 
TTE is effected by the control logic 50 of the memory management unit 28. The 
result of the modification to the TTE is that any subsequent attempts to address the 
5 resource will pick up not the address of the resource from the TTE, but rather the 
address of the divert location or resource (eg, the divert page 86). 

The trap handler is also operable in step S7 to effect the processing of the exception 
caused by the faulty resource access. The exception processing represented by step S7 
10 can be started in parallel with step S5, although this will take a considerably longer 
time than merely providing the divert address to the memory management unit 28. 

Figure 10 also represents a subsequent resource access attempt at S8. As the divert 
address has already been recorded in the TTE for the received address, the divert 
15 address will be used in step S9 for the address translation whereby access is effected 
in step S 10 to the divert resource (eg, the divert page 86). This has the result that a 
valid resource access will be made (albeit to a resource other than the intended 
resource), no trap needs to be taken, and no further exception processing needs to be 
effected. 



As mentioned above, optionally, a fake response generator 88 could be activated as 
the divert resource in order to generate a fake response for simulating a true access to 
the resource to which the original access was directed. 



20 



25 



As an alternative, the fake response generator 88 could be implemented in hardware in 
the memory management unit. The fake response generator could include storage 
containing fake responses to be returned as the faked response. 
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In the above-described embodiment of the invention, the resource access control is 
provided using an address translation mechanism in a processor, for example in the 
processor's memory management unit. However, the benefits of the invention can 
also be achieved using address translation mechanisms at other parts of the computer 
5 system. One such example is in a bridge such as the I/O bridge 18 between the buses 
14 and 20. In such a case, the trap handler would be operable to instruct the address 
translation mechanism in the bridge to change the appropriate address mapping. 

The computer program implementing the trap handler can be provided as a computer 
10 program on a carrier medium. The carrier medium could be storage medium (such as 
an optical, a magneto-optical, a magnetic or a solid state storage medium configured 
as a disk, tape or solid state device, etc), or a transmission medium (such as a 
telephonic, wireless, copper, optical or other wired medium, etc), or a mixture thereof, 
as appropriate. 



Accordingly, there has been described an apparatus and a method to provide efficient 
resource access control in a computer system. A trap handler is provided for handling 
a trap in the event of a faulty resource access being detected is arranged to define a 
diversion for subsequent access attempts to the same resource. An address translation 

20 mechanism is responsive to indication of a diversion for a resource access to modify 
an address mapping, whereby subsequent attempts to access the resource are diverted 
in accordance with the diversion. The trap handler can be arranged in a conventional 
manner to process an exception of the first faulty access to the resource. However, by 
defining the diversion, which can be used to map further attempts to access the same 

25 resource, unnecessary exception processing can be avoided. 



15 



Although particular embodiments of the invention have been described, it will be 
appreciated that many modifications/additions and/or substitutions may be made 
within the scope of the invention. 




SUN REF: P5128 20 SUN PROPRIETARY/ 

CONFIDENTIAL 

For example, the divert address need not be supplied by the trap handler. The trap 
handler can simply instigate the diversion by signaling the address translation 
mechanism to effect the diversion. The address translation mechanism can then be 
arranged to replace the usual address translation with an alternative one from some 
5 predefined register or memory address. 

Rather than actually changing the address stored in the TTE, one or more bits in the 
TTE can be designated as a divert flag, and this divert flag can be set when a divert 
address is to be used rather than the normal translation address for the TTE. For 

10 example an undefined bit (say bit 61) in the tag field of the TTE illustrated in Figure 8 
could be designated as a divert flag bit. The divert address can be held, for example, 
in a predefined register or memory location that forms part of the address translation 
mechanism. In such an embodiment, steps S5, S6 and S9 of the method described 
with reference to Figure 10 are modified. In step S5 the trap handler is operable to 

15 instruct the address translation mechanism to set the divert flag bit. In step S6, the 
control logic of the address translation mechanism is operable to modify the TTE for 
the resource concerned by setting the divert flag bit. In step S9 the address translation 
mechanism is arranged to react to the flag bit of the TTE entry for the received 
address to use the divert address from the register or specific memory location for the 

20 resource access, rather than the address translation identified in the TTE. 

As a further alternative based on the use of a divert flag, rather than using a specific 
divert address from a divert register or memory location in step S9, the address 
translation mechanism can be arranged to modify the normal translated address 
25 identified in the TTE. Such a remapped address also forms a divert address. For 
example one bit might be changed to divert the translated address into an otherwise 
unused address range. A fake response generator can be configured to respond to an 
address in that otherwise unused address range, whereby the fake response generator 
alone will respond to the diverted address. 
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These alternative embodiments enable a diversion to be defined that can be used to 
map further attempts to access a faulty resource, thereby avoiding unnecessary 
exception processing. 

Although the described embodiments employ translation tables, it will be appreciated 
that the translation entries need not be stored in tabular form, but could be held in any 
other suitable form, for example in a linked list. Thus for example, where reference is 
made to a table or sub-table above, this could be replaced by a reference to a list, or 



Moreover, the invention is not limited to any particular technology for looking up 
translation entries. For example, where tables are used, these could be fully or set 
associative as appropriate. 



10 sub-list. 
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An embodiment of processor according to the invention could be used in both single 
processor and multiple processor systems. 



